<!DOCTYPE HTML>
<html lang="zh-CN">


<head>
    <meta charset="utf-8">
    <meta name="keywords" content="JS学习笔记, Kevin&#39;s Blog">
    <meta name="description" content="">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
    <meta name="renderer" content="webkit|ie-stand|ie-comp">
    <meta name="mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
    <!-- Global site tag (gtag.js) - Google Analytics -->


    <title>JS学习笔记 | Kevin&#39;s Blog</title>
    <link rel="icon" type="image/png" href="/icon.png">

    <link rel="stylesheet" type="text/css" href="/libs/awesome/css/all.css">
    <link rel="stylesheet" type="text/css" href="/libs/materialize/materialize.min.css">
    <link rel="stylesheet" type="text/css" href="/libs/aos/aos.css">
    <link rel="stylesheet" type="text/css" href="/libs/animate/animate.min.css">
    <link rel="stylesheet" type="text/css" href="/libs/lightGallery/css/lightgallery.min.css">
    <link rel="stylesheet" type="text/css" href="/css/matery.css">
    <link rel="stylesheet" type="text/css" href="/css/my.css">

    <script src="/libs/jquery/jquery.min.js"></script>

<meta name="generator" content="Hexo 5.4.0"></head>




<body>
    <header class="navbar-fixed">
    <nav id="headNav" class="bg-color nav-transparent">
        <div id="navContainer" class="nav-wrapper container">
            <div class="brand-logo">
                <a href="/" class="waves-effect waves-light">
                    
                    <img src="/icon.png" class="logo-img" alt="LOGO">
                    
                    <span class="logo-span">Kevin&#39;s Blog</span>
                </a>
            </div>
            

<a href="#" data-target="mobile-nav" class="sidenav-trigger button-collapse"><i class="fas fa-bars"></i></a>
<ul class="right nav-menu">
  
  <li class="hide-on-med-and-down nav-item">
    
    <a href="/" class="waves-effect waves-light">
      
      <i class="fas fa-home" style="zoom: 0.6;"></i>
      
      <span>博客主页</span>
    </a>
    
  </li>
  
  <li class="hide-on-med-and-down nav-item">
    
    <a href="/archives" class="waves-effect waves-light">
      
      <i class="fas fa-archive" style="zoom: 0.6;"></i>
      
      <span>博客归档</span>
    </a>
    
  </li>
  
  <li class="hide-on-med-and-down nav-item">
    
    <a href="/about" class="waves-effect waves-light">
      
      <i class="fas fa-user-circle" style="zoom: 0.6;"></i>
      
      <span>关于Kevin</span>
    </a>
    
  </li>
  
  <li class="hide-on-med-and-down nav-item">
    
    <a href="/friends" class="waves-effect waves-light">
      
      <i class="fas fa-address-book" style="zoom: 0.6;"></i>
      
      <span>查看大佬</span>
    </a>
    
  </li>
  
  <li>
    <a href="#searchModal" class="modal-trigger waves-effect waves-light">
      <i id="searchIcon" class="fas fa-search" title="搜索" style="zoom: 0.85;"></i>
    </a>
  </li>
</ul>


<div id="mobile-nav" class="side-nav sidenav">

    <div class="mobile-head bg-color">
        
        <img src="/icon.png" class="logo-img circle responsive-img">
        
        <div class="logo-name">Kevin&#39;s Blog</div>
        <div class="logo-desc">
            
            Never really desperate, only the lost of the soul.
            
        </div>
    </div>

    

    <ul class="menu-list mobile-menu-list">
        
        <li class="m-nav-item">
	  
		<a href="/" class="waves-effect waves-light">
			
			    <i class="fa-fw fas fa-home"></i>
			
			博客主页
		</a>
          
        </li>
        
        <li class="m-nav-item">
	  
		<a href="/archives" class="waves-effect waves-light">
			
			    <i class="fa-fw fas fa-archive"></i>
			
			博客归档
		</a>
          
        </li>
        
        <li class="m-nav-item">
	  
		<a href="/about" class="waves-effect waves-light">
			
			    <i class="fa-fw fas fa-user-circle"></i>
			
			关于Kevin
		</a>
          
        </li>
        
        <li class="m-nav-item">
	  
		<a href="/friends" class="waves-effect waves-light">
			
			    <i class="fa-fw fas fa-address-book"></i>
			
			查看大佬
		</a>
          
        </li>
        
        
        <li><div class="divider"></div></li>
        <li>
            <a href="https://github.com/ZKQevin" class="waves-effect waves-light" target="_blank">
                <i class="fab fa-github-square fa-fw"></i>Fork Me
            </a>
        </li>
        
    </ul>
</div>


        </div>

        
            <style>
    .nav-transparent .github-corner {
        display: none !important;
    }

    .github-corner {
        position: absolute;
        z-index: 10;
        top: 0;
        right: 0;
        border: 0;
        transform: scale(1.1);
    }

    .github-corner svg {
        color: #0f9d58;
        fill: #fff;
        height: 64px;
        width: 64px;
    }

    .github-corner:hover .octo-arm {
        animation: a 0.56s ease-in-out;
    }

    .github-corner .octo-arm {
        animation: none;
    }

    @keyframes a {
        0%,
        to {
            transform: rotate(0);
        }
        20%,
        60% {
            transform: rotate(-25deg);
        }
        40%,
        80% {
            transform: rotate(10deg);
        }
    }
</style>

<a href="https://github.com/ZKQevin" class="github-corner tooltipped hide-on-med-and-down" target="_blank"
   data-tooltip="Fork Me" data-position="left" data-delay="50">
    <svg viewBox="0 0 250 250" aria-hidden="true">
        <path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"></path>
        <path d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2"
              fill="currentColor" style="transform-origin: 130px 106px;" class="octo-arm"></path>
        <path d="M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z"
              fill="currentColor" class="octo-body"></path>
    </svg>
</a>
        
    </nav>

</header>

    



<div class="bg-cover pd-header post-cover" style="background-image: url('/medias/featureimages/9.jpg')">
    <div class="container" style="right: 0px;left: 0px;">
        <div class="row">
            <div class="col s12 m12 l12">
                <div class="brand">
                    <h1 class="description center-align post-title">JS学习笔记</h1>
                </div>
            </div>
        </div>
    </div>
</div>




<main class="post-container content">

    
    <link rel="stylesheet" href="/libs/tocbot/tocbot.css">
<style>
    #articleContent h1::before,
    #articleContent h2::before,
    #articleContent h3::before,
    #articleContent h4::before,
    #articleContent h5::before,
    #articleContent h6::before {
        display: block;
        content: " ";
        height: 100px;
        margin-top: -100px;
        visibility: hidden;
    }

    #articleContent :focus {
        outline: none;
    }

    .toc-fixed {
        position: fixed;
        top: 64px;
    }

    .toc-widget {
        width: 345px;
        padding-left: 20px;
    }

    .toc-widget .toc-title {
        padding: 35px 0 15px 17px;
        font-size: 1.5rem;
        font-weight: bold;
        line-height: 1.5rem;
    }

    .toc-widget ol {
        padding: 0;
        list-style: none;
    }

    #toc-content {
        padding-bottom: 30px;
        overflow: auto;
    }

    #toc-content ol {
        padding-left: 10px;
    }

    #toc-content ol li {
        padding-left: 10px;
    }

    #toc-content .toc-link:hover {
        color: #42b983;
        font-weight: 700;
        text-decoration: underline;
    }

    #toc-content .toc-link::before {
        background-color: transparent;
        max-height: 25px;

        position: absolute;
        right: 23.5vw;
        display: block;
    }

    #toc-content .is-active-link {
        color: #42b983;
    }

    #floating-toc-btn {
        position: fixed;
        right: 15px;
        bottom: 76px;
        padding-top: 15px;
        margin-bottom: 0;
        z-index: 998;
    }

    #floating-toc-btn .btn-floating {
        width: 48px;
        height: 48px;
    }

    #floating-toc-btn .btn-floating i {
        line-height: 48px;
        font-size: 1.4rem;
    }
</style>
<div class="row">
    <div id="main-content" class="col s12 m12 l9">
        <!-- 文章内容详情 -->
<div id="artDetail">
    <div class="card">
        <div class="card-content article-info">
            <div class="row tag-cate">
                <div class="col s7">
                    
                          <div class="article-tag">
                            <span class="chip bg-color">无标签</span>
                          </div>
                    
                </div>
                <div class="col s5 right-align">
                    
                </div>
            </div>

            <div class="post-info">
                
                <div class="post-date info-break-policy">
                    <i class="far fa-calendar-minus fa-fw"></i>发布日期:&nbsp;&nbsp;
                    2021-03-09
                </div>
                

                
                <div class="post-date info-break-policy">
                    <i class="far fa-calendar-check fa-fw"></i>更新日期:&nbsp;&nbsp;
                    2021-09-10
                </div>
                

                

                

                
            </div>
        </div>
        <hr class="clearfix">

        

        

        <div class="card-content article-card-content">
            <div id="articleContent">
                <p>﻿</p>
<p>Dom查询其它方法</p>
<p>获取body标签getElementByTagName(“body”)[0]</p>
<p>在document中有一个属性body，它保存的是body的引用</p>
<p>documentElement保存的是html的根标签</p>
<p>document.all代表页面中的所有元素</p>
<p>document.querySelector()这个方法很强大，需要一个选择器的字符串作为参数，可以根据一个CSS选择器来查询一个元素节点对象。</p>
<p>使用该方法会返回唯一的一个元素，如果满足条件的元素有多个那么它只会返回第一个。</p>
<p>document.querySelectorAll()这个方法就可以查询到所有的classname的方法。不同的是符合条件的元素封装到一个数组中进行返回。即使只有一个也返回数组</p>
<p>字面量：都是一些不可改变的值</p>
<p>自变量都是可以直接使用，但是我们一般都不直接使用字面量<br>变量：可以用来保存字面量，变量的值是可以任意改变的</p>
<p>变量更加方便我们使用，所以开发中通过变量保存一个字面量<br>05.尚硅谷_JS基础_字面量和变量P5 - 01:53</p>
<p>标识符</p>
<p>在JS中自主命令的都称为标识符<br>例如：变量名、函数名、属性名都属于标识符<br>命名规则如下：<br>标识符可以含有字母、数字、__、$</p>
<p>标识符不能以数字开头。</p>
<p>标识符不能是ES中的关键字或保留字。</p>
<p>标识符一般采用驼峰命名法。helloWorld</p>
<p>JS底层保存标识符实际上是采用的Unicode编码，<br>07.尚硅谷_JS基础_字符串P7 - 00:26</p>
<p>JS中一共有六种数据类型</p>
<p>String 字符串<br>Number 数字<br>Boolean 布尔值<br>Null 控制<br>Undefinged 未定义<br>Object 对象<br>引用数据类型：Object，其它都是基本数据类型</p>
<p>字符串：</p>
<p>在JS中字符需要使用引号引起来（单双引号都可以）</p>
<p>引号不能嵌套，双引号不能放双引号，单引号不能放单引号（如果非要用就必须使用转义字符\）</p>
<p>当表示一些特殊符号时可以使用\进行转义</p>
<p>&quot;表示“ \‘表示’</p>
<p>﻿</p>
<p>07.尚硅谷_JS基础_字符串P7 - 14:42</p>
<p>﻿</p>
<p>﻿</p>
<p>08.尚硅谷_JS基础_NumberP8 - 00:40</p>
<p>﻿</p>
<p>数值类型，浮点整数都是</p>
<p>使用typeof来检查一个类型的变量</p>
<p>ptyeof a表示检查a变量的类型</p>
<p>JS表示Number的最大值number.MAX_VALUE</p>
<p>如果使用的Number表示的数字超过了最大值，则会返回一个Infinity无穷。</p>
<p>使用typeof检查Infinity也会返回Number他也是一个数字</p>
<p>NaN是一个特殊的数字，表示Not A Number不是一个数字</p>
<p>Number.MIN_VALUE表示0以上可表示的最小值5e-300</p>
<p>var c=0.1+0.2如果使用JS进行浮点元素，可能得到一个不精确的结果，所以千万不要使用JS进行对精确度要求较高的运算</p>
<p>﻿</p>
<p>09.尚硅谷_JS基础_布尔值P9 - 00:16</p>
<p>﻿</p>
<p>布尔值只有两个：</p>
<p>True和False</p>
<p>﻿</p>
<p>10.尚硅谷_JS基础_Null和UndefinedP10 - 00:45</p>
<p>﻿</p>
<p>Null类型的值只有一个，就是Null</p>
<p>Null值专门表示一个为空的对象</p>
<p>Null进行检查时返回的是Object的</p>
<p>Undefined类型的值只有一个，就undefined（未定义）</p>
<p>当声明一个变量，但并不给他赋值，那它就是undefined</p>
<p>使用typeof检查时也是undefined</p>
<p>﻿</p>
<p>11.尚硅谷_JS基础_强制类型转换-StringP11 - 00:03</p>
<p>﻿</p>
<p>强制类型转换：</p>
<p>指将一个类型数据强制转换为其它的数据类型</p>
<p>类型转换主要是指，将其它的数据类型，转换为</p>
<p>String Number Boolean</p>
<p>将其它的数据类型转换为String</p>
<p>方式1、调用被转换数据的ToSting（）方法（这种方法不会改变原始的数据类型）</p>
<p>Null和Undefined没有ToString方法如果硬调用会保存</p>
<p>方式2、调用String（）函数，并将被转换的数据作为参数传递给函数。</p>
<p>对于Number和Boolean实际上调用的ToString（）方法但是对于Null直接转换为“null”，将Undefined转换为“Undefined”</p>
<p>﻿</p>
<p>12.尚硅谷_JS基础_强制类型转换-NumberP12 - 00:00</p>
<p>﻿</p>
<p>将其它的数据类型转换为Number</p>
<p>转换方式一：</p>
<p>使用Number（）函数</p>
<p>-字符串转换为数字</p>
<p>1.如果是纯数字的字符串，则直接转换为纯数字的字符串</p>
<p>2.如果字符串中有非数字的内容，则转换为NaN</p>
<ol start="3">
<li>如果字符串是空船或者是一个全是空格的字符，那么将转换为0</li>
</ol>
<p>-布尔值转换为数字</p>
<p>1.True转为1，False转为0</p>
<p>-Null转换为0</p>
<p>-Undefined转换数字为NaN</p>
<p>转换方式二：</p>
<p>例如：a=123px123，使用下面方法可以转出123来不转换出px后面的直接忽略掉</p>
<p>parseInt（）把一个字符串转换为一个整数</p>
<p>如果对非String使用parseInt（）或parseFloat（）先转换为String再转换成为number</p>
<p>parseFloat（）把一个字符串转换为一个浮点数</p>
<p>﻿</p>
<p>13.尚硅谷_JS基础_其他进制的数字P13 - 00:11</p>
<p>﻿</p>
<p>其它进制的数据</p>
<p>在js中，如果需要表示16进制的数字，则需要以0x开头</p>
<p>例如a=0x10；那么a的输出值就是16</p>
<p>如果需要表示8进制的数字，则需要以0开头</p>
<p>例如a=070；那么a的输出为56</p>
<p>如果需要表示2进制的数字，则需要以0b开头</p>
<p>例如a=0b10,；那么a的输出为2</p>
<p>a=parseInt(a,10)传递第二个参数，来指定数字的进制</p>
<p>﻿</p>
<p>14.尚硅谷_JS基础_转换为BooleanP14 - 00:12</p>
<p>﻿</p>
<p>转换为Boolean</p>
<p>方式：使用Boolean（）函数</p>
<p>var a=123;</p>
<p>a=Boolean(a)转换为True。</p>
<p>数字转Boolean规则为0和NaN为False其余为True</p>
<p>字符串转Boolean除了空串为false其余为True</p>
<p>Null和Undefined只能转换为False</p>
<p>对象也会转换为True</p>
<p>﻿</p>
<p>15.尚硅谷_JS基础_算数运算符P15 - 00:15</p>
<p>﻿</p>
<p>任何值和字符串相加都会转换为字符串再做拼接</p>
<p>隐式的类型转换，一个数值number+一个””空字符串，他就会自动调用ToString方法进行转换。</p>
<p>除了+法之外，其它都会把他转成Number形在进行</p>
<p>（隐式转换）可以通过一个值 -0 *1 /1来将其转换为Number</p>
<p>原理和Number()函数（显式转换）一样，使用起来更简单</p>
<p>﻿</p>
<p>16.尚硅谷_JS基础_一元运算符P16 - 00:03</p>
<p>﻿</p>
<p>单目运算符（一元运算符）：</p>
<p>+正号</p>
<p>不会对数字产生任何影响</p>
<p>-负号</p>
<p>对原来的数字进行取反</p>
<p>可以对一个其他的数据使用+，来将进行转换为Number</p>
<p>例如：a=1+(+”2”)+3，a就会输出为6</p>
<p>﻿</p>
<p>17.尚硅谷_JS基础_自增和自减P17 - 00:28</p>
<p>﻿</p>
<p>++通过自增可以使变量在自身的基础上加1</p>
<p>后++和前++，无论是哪个都会使原变量的值自增1，</p>
<p>不同的是a++和++a的值不同</p>
<p>a++的值等于原变量的值（自增前的值）后自增</p>
<p>++a的值等于原变量的值（自增后的值）先自增</p>
<p>–通过自减可以是变量在自身的基础上减1</p>
<p>前–和后–，无论是a–还是–a都会立即使原变量的值自减1</p>
<p>不同的是a–和–a的值不同（与前后++规则相同）</p>
<p>﻿</p>
<p>18.尚硅谷_JS基础_自增练习P18 - 00:20</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>19.尚硅谷_JS基础_逻辑运算符P19 - 00:13</p>
<p>﻿</p>
<p>如果对非Boolean值进行取反，那么他就先转换为Boolean再进行取反</p>
<p>﻿</p>
<p>20.尚硅谷_JS基础_非布尔值的与或运算P20 - 00:02</p>
<p>﻿</p>
<p>对于非布尔值的与或运算，会将其转换为布尔值，然后再运算并且返回原值</p>
<p>与运算，如果两个都为True则返回后面的</p>
<p>如果有False则返回0，如果有两个False则返回靠前的False</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>21.尚硅谷_JS基础_赋值运算符P21 - 00:11</p>
<p>﻿</p>
<p>﻿</p>
<p>23.尚硅谷_JS基础_Unicode编码表P23 - 00:12</p>
<p>﻿</p>
<p>在字符串中使用转移字符表\u</p>
<p>例如：我们要输出一个1就是\u2040</p>
<p>在网页中就是&amp;#；不过这儿需要的是十进制，需要把十六进制转为十进制</p>
<p>﻿</p>
<p>24尚硅谷_JS基础_相等运算符P24 - 00:24</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>使用==是，他会自动转换类型，转换成什么不一定大部分会转换成为数字</p>
<p>NaN不和任何值相等（包括自身都不等）。Undefined衍生自Null所以他和Null相等</p>
<p>可以通过isNaN（）函数来判断是否是NaN返回true和False</p>
<p>===全等</p>
<p>判断两个值是否全等，它和相似相等，但是不会做相应转换</p>
<p>！==全等</p>
<p>判断两个值是否不全等，它和不相等相似，但不会进行转换</p>
<p>﻿</p>
<p>25.尚硅谷_JS基础_条件运算符P25 - 00:05</p>
<p>﻿</p>
<p>条件运算符也叫三元运算符</p>
<p>语法：</p>
<p>条件表达式?语句1：语句2;</p>
<p>﻿ ﻿</p>
<p>会将其条件表达式转换为布尔值之后再进行运算</p>
<p>﻿</p>
<p>26.尚硅谷_JS基础_运算符的优先级P26 - 00:41</p>
<p>﻿</p>
<p>，逗号可以同时声明多个变量</p>
<p>可以使用()来改变优先级</p>
<p>﻿</p>
<p>27.尚硅谷_JS基础_代码块P27 - 00:24</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>JS中的代码块，只具有分组的作用，没有其他的用途</p>
<p>代码块内容的内容，在外部是完全可见的</p>
<p>﻿</p>
<p>28.尚硅谷_JS基础_if语句（一）P28 - 00:27</p>
<p>﻿</p>
<p>﻿</p>
<p>29.尚硅谷_JS基础_if语句（二）P29 - 00:06</p>
<p>﻿</p>
<p>prompt（）可以弹出一个提示框，该提示框会带有一个文本框，用户可以输入内容，该函数需要一个字符串作为阐述，该字符串将会提示框的提示文字</p>
<p>﻿</p>
<p>32.尚硅谷_JS基础_if练习二P32 - 12:06</p>
<p>﻿</p>
<p>var num1=+prompt(“请输入第一个数：”)//这样读取出来的是一个数字类型</p>
<p>﻿</p>
<p>33.尚硅谷_JS基础_条件分支语句P33 - 00:29</p>
<p>﻿</p>
<p>﻿</p>
<p>34.尚硅谷_JS基础_switch练习P34 - 07:18</p>
<p>﻿</p>
<p>Switch（）{</p>
<p>Case：</p>
<p>Case：</p>
<p>default：</p>
<p>}</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>35.尚硅谷_JS基础_while循环P35 - 11:49</p>
<p>﻿</p>
<p>while和dowhile</p>
<p>﻿</p>
<p>36.尚硅谷_JS基础_while的练习P36 - 12:08</p>
<p>﻿</p>
<p>﻿</p>
<p>37.尚硅谷_JS基础_for循环P37 - 00:04</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>38.尚硅谷_JS基础_for循环P38 - 00:10</p>
<p>﻿</p>
<p>﻿</p>
<p>39.尚硅谷_JS基础_质数练习P39 - 00:11</p>
<p>﻿</p>
<p>﻿</p>
<p>46.尚硅谷_JS基础_对象的简介P46 - 00:07</p>
<p>﻿</p>
<p>基本数据类型都是单一的值，值和值之间没有任何的联系。</p>
<p>在JS中表示一个人的信息</p>
<p>对象属于一种复合的数据类型，在对象中可以保存多个不同数据类型的属性。</p>
<p>对象的分类：</p>
<p>1、内建对象</p>
<p>在ES标准中定义的对象，在任何的ES的实现中都可以使用</p>
<p>2、宿主对象</p>
<p>由JS的运行环境提供的对象，目前来讲主要指由浏览器提供的对象</p>
<p>比如BOM DOM</p>
<p>console.log()、Domcument对象都是浏览器搞好的</p>
<p>3、自定义对象</p>
<p>由开发人员创建的对象</p>
<p>﻿</p>
<p>47.尚硅谷_JS基础_对象的基本操作P47 - 00:04</p>
<p>﻿</p>
<p>创建对象</p>
<p>var obj=new Object();//使用new关键字调用的函数，是构造函数constructor。构造函数是专门用来创建对象的函数</p>
<p>使用typeof检查一个对象返回object。</p>
<p>//向对象中添加属性</p>
<p>语法：对象.属性名=属性值；</p>
<p>//读取对象中的属性</p>
<p>语法：对象.属性名</p>
<p>如果读取对象中没有的属性，不会报错而会返回undefined</p>
<p>//修改对象的属性值</p>
<p>语法：对象.属性名=新值</p>
<p>//删除对象的属性</p>
<p>语法：delete 对象.属性名</p>
<p>﻿</p>
<p>48.尚硅谷_JS基础_属性名和属性值P48 - 00:22</p>
<p>﻿</p>
<p>像对象中添加属性</p>
<p>属性名：</p>
<p>对象的属性名不强制要求遵守标识符的规（什么都可以用），但是尽量按照标识符的规范去做</p>
<p>如果确确实实需要使用特殊的属性名，不能采用.的方式来操作</p>
<p>需要使用另一种方式：</p>
<p>语法：对象【“属性名”】=属性值。取值的时候也需要采用对象【“属性名”】</p>
<p>使用【】这种形式去操作属性，更加灵活；</p>
<p>在【】中可以直接传递一个变量，这样变量是多少就会读取那个属性</p>
<p>﻿ ﻿</p>
<p>﻿ ﻿</p>
<p>﻿ ﻿</p>
<p>//属性值</p>
<p>JS对象的属性值，可以是任意的数据类型</p>
<p>//in运算符</p>
<p>通过该运算符可以检查一个对象中是否含有指定的属性</p>
<p>如果有返回true，没有返回的false</p>
<p>语法：“属性名” in 对象</p>
<p>﻿</p>
<p>49.尚硅谷_JS基础_基本数据类型和引用数据类型P49 - 00:08</p>
<p>﻿</p>
<p>JS中的变量都是保存在栈里面的</p>
<p>基本数据类型的值直接在栈内存中存储</p>
<p>值与值之间是独立存在的，修改一个变量不会影响其他的变量</p>
<p>对象是保存到堆内存中的，没创建一个新的对象，就会在堆内存中开辟出一个新的空间。。而变量中保存的是内存的地址（对象的引用），如果两个变量保存的是同一个对象的引用，当一个通过一个变量修改堆内存中的值之后另外的引用也会改变。</p>
<p>当比较两个基本数据类型的值时，就是直接去比较的值</p>
<p>而比较两个应用数据类型时，它是比较他们的内存地址。</p>
<p>两个对象，即使他们长得一模一样，他们也不是相等的（内存地址不一样）</p>
<p>﻿</p>
<p>50.尚硅谷_JS基础_对象字面量P50 - 00:06</p>
<p>﻿</p>
<p>使用字面量创建对象</p>
<p>var obj={}相等于var obj=new Object()；</p>
<p>使用对象字面量，可以在创建对象时，直接指定对象中的属性</p>
<p>语法：{属性名：属性值，属性名：属性值……}</p>
<p>对象字面量可以加引号也可以不加，建议不加</p>
<p>如果要使用一些特殊的名字，则必须加引号</p>
<p>属性名和属性值是一组一组的名值对结构，</p>
<p>名值对之间使用：冒号连接，多个名值对之间用，逗号隔开，最后一个不要写，逗号</p>
<p>﻿</p>
<p>51.尚硅谷_JS基础_函数的简介P51 - 00:21</p>
<p>﻿</p>
<p>函数：function</p>
<p>-函数也是一个对象</p>
<p>-函数中可以封装一些功能（代码），在需要时可以执行这些功能（代码）</p>
<p>-函数中可以保存代码需要时调用</p>
<p>//创建一个函数对象（构造方法）</p>
<p>var fun=new Function()</p>
<p>使用typeof检查一个函数对象时，会返回function</p>
<p>//封装到函数中的代码不会立即执行</p>
<p>//调用函数 语法：函数对象（）</p>
<p>//函数对象可以实现常用的对象功能</p>
<p>//我们在实际开发中很少使用构造函数来创建对象</p>
<p>直接使用函数声明来创建一个函数</p>
<p>语法：function 函数名（[形参1，形参2，形参N]）#带有中括号的代表着这个形参可以写也可以不写</p>
<p>匿名函数创造的方法：var func=function(){}</p>
<p>﻿</p>
<p>52.尚硅谷_JS基础_函数的参数P52 - 00:16</p>
<p>﻿</p>
<p>多个形参之间使用，逗号隔开，声明形参就相当于在函数内部声明了对应的变量但并不赋值</p>
<p>调用函数时不会检查实参的类型所以要注意是否有可能接收到非法的参数如果有可能则需要对类型的检查。</p>
<p>调用函数时，解析器也不会检查实参的数量，多余的实参不会被赋值（不用）如果实参少于形参的数量，没有被赋值的就为undefined</p>
<p>﻿</p>
<p>53.尚硅谷_JS基础_函数的返回值P53 - 00:37</p>
<p>﻿</p>
<p>return方法，可以作为结果返回（可以返回任何类型的值）</p>
<p>函数return之后的方法不会执行</p>
<p>﻿</p>
<p>54.尚硅谷_JS基础_实参可以是任何值P54 - 00:17</p>
<p>﻿</p>
<p>实参是任意的类型，也可以是一个对象</p>
<p>当我们的参数过多时，可以将参数封装到一个对象中，然后通过对象传递</p>
<p>实参可以是一个对象，也能是一个函数。将一个匿名函数作为实参传递给一个函数开发中经常遇到</p>
<p>如果不加括号传递一个函数的话传递的是那个函数处理的返回值在传递给他，如果加括号则传递的是函数这个对象，那么传入进去之后那个函数就可以使用被传入进来函数的方法</p>
<p>﻿</p>
<p>55.尚硅谷_JS基础_返回值的类型P55 - 00:19</p>
<p>﻿</p>
<p>continue跳过当次循环，但是还是要进行下一次循环</p>
<p>break跳出整个循环</p>
<p>return退出整个函数</p>
<p>返回值可以是任意的数据类型也可以是一个对象还可以是一个函数</p>
<p>可以在函数内部还可以声明函数，也可以作为返回值进行返回。</p>
<p>﻿</p>
<p>56.尚硅谷_JS基础_立即执行函数P56 - 00:11</p>
<p>﻿</p>
<p>调用一个匿名函数</p>
<p>(function(){alert(“我是一个匿名函数~~~”);})();</p>
<p>函数定义完就会被立即执行一次。</p>
<p>﻿</p>
<p>57.尚硅谷_JS基础_方法P57 - 00:07</p>
<p>﻿</p>
<p>对象的属性可以是任何的数据类型，也可以是个函数</p>
<p>函数也可以成为对象的属性，如果一个函数作为一个对象的属性保存，</p>
<p>那么我们成这个函数时这个对象的方法，调用函数就说调用对象的方法（method），但是它只是名称上的区别，没有其它的区别。</p>
<p>//调方法</p>
<p>obj.function()</p>
<p>//调函数</p>
<p>function()</p>
<p>枚举：</p>
<p>要知道对象中的所有属性。则需要使用枚举的方法，一个一个的取出来。使用for in语句</p>
<p>语法：for(var 变量 in 对象){}</p>
<p>还可以使用for(var n in boj){console.log(obj[n])}来输出属性值</p>
<p>﻿</p>
<p>58.尚硅谷_JS基础_全局作用域P58 - 00:08</p>
<p>﻿</p>
<p>作用域</p>
<p>-作用域指一个变量的作用范围</p>
<p>-在JS中一共有两种作用域：</p>
<p>全局作用域：</p>
<p>-直接编写在script中的JS代码，都作用在全局作用域</p>
<p>-全局作用域在页面打开的时候创建，页面关闭的时候销毁</p>
<p>-全局作用域中有一个全局对象window，我们可以直接使用。他代表的是一个浏览器的窗口。</p>
<p>-全局作用域中的变量都会作为window对象的属性保存</p>
<p>-全局作用域中的函数都会作为window对象的方法保存</p>
<p>1、变量的声明提前：</p>
<p>-使用var关键字声明的变量，会在所有的代码执行之前被声明，但是如果声明变量时不使用var关键字，则变量不会被声明提前。</p>
<p>2、函数的声明提前：</p>
<p>-使用函数声明形式创建的函数function函数（）{}。它会在所有的代码执行之前被创建。所以我们可以在函数声明前进行调用。</p>
<p>-使用函数表达式创建的函数var fun=function(){}。不会被提前创建。</p>
<p>-全局作用域中的变量都是全局变量，在我们的页面的任意部分都可以访问到</p>
<p>﻿</p>
<p>59.尚硅谷_JS基础_函数作用域P59 - 00:04</p>
<p>﻿</p>
<p>函数作用域：</p>
<p>-调用函数时创建函数作用域，函数执行完毕后，函数作用域销毁</p>
<p>-每调用一次函数就会创建一个新的函数作用域，他们之间是互相独立的</p>
<p>-在函数作用域中可以访问到全局作用域的变量，但是在全局作用域中无法访问到函数作用域中的变量</p>
<p>-当在函数作用域中操作一个变量时，它会现在自身作用域中寻找，如果有就直接使用，如果没有则向上一级作用域中寻找（并不是指的是全局作用域）可以是上一级的函数中的变量。最后才会找到全局作用域中。如果全局作用域中都没有那就报错没有定义</p>
<p>﻿ ﻿</p>
<p>-在函数作用域中也有提前声明。类似于全局作用域的提前声明。</p>
<p>-在函数中如果不写var的话那就会成为全局变量（相当于window.变量名=变量值）</p>
<p>-定义形参就相当于在函数作用域中声明了变量。</p>
<p>﻿</p>
<p>60.尚硅谷_JS基础_debugP60 - 00:25</p>
<p>﻿</p>
<p>使用浏览器的Sources可以悬停一步一步的执行，可以验证var是否已经提前声明，添加进watch中就可以看到。</p>
<p>﻿</p>
<p>61.尚硅谷_JS基础_thisP61 - 00:03</p>
<p>﻿</p>
<p>解析器（浏览器）在调用函数每次都会向函数内部传递进一个隐含的参数。这个隐含的参数就是this。this指向的是一个对象。</p>
<p>这个对象我们称为函数执行的上下文对象。</p>
<p>根据函数的调用方式不同，this会指向不同的方向</p>
<p>1、以函数的形式调用时，this永远都是window。</p>
<p>2、以方法的形式调用时，this就是方法调用的对象</p>
<p>﻿</p>
<p>62.尚硅谷_JS基础_this补充P62 - 00:14</p>
<p>﻿</p>
<p>this可以根据调用者的不同来决定被调用的东西是什么，相当于java里面的父类</p>
<p>﻿</p>
<p>63.尚硅谷_JS基础_使用工厂方法创建对象P63 - 03:22</p>
<p>﻿</p>
<p>﻿</p>
<p>64.尚硅谷_JS基础_构造函数P64 - 17:57</p>
<p>﻿</p>
<p>1.立刻创建一个新的对象</p>
<p>2.将新建的对象设置为函数中this,在构造函数中可以使用this来引用新建的对象</p>
<p>3.逐行执行函数中的代码</p>
<p>4.将新建的对象作为返回值返回</p>
<p>使用同一个构造函数创建的对象，我们成为一类对象，也构造了一个类。创建的构造对象成为一个类的实例</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>65.尚硅谷_JS基础_.构造函数修改P65 - 00:01</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>直接在作用域中进行定义，让所有的构造方法都去调用同一个函数</p>
<p>﻿</p>
<p>66.尚硅谷_JS基础_原型对象P66 - 00:54</p>
<p>﻿</p>
<p>函数定义在全局作用域，污染全局作用域的命名空间，而且定义在全局作用域中也很不安全。</p>
<p>prototype圆形</p>
<p>我们所创建的每一个函数，解析器都会向函数中添加一个属性prototype</p>
<p>-这个属性对应着一个对象，这个对象就是我们所谓的原型对象</p>
<p>﻿ ﻿</p>
<p>如果函数作为普通函数调用时prototype没有任何作用</p>
<p>当以构造对象进行调用时，它所创建的对象中都会有一个隐藏的属性指向该构造函数的原型对象，我们可以通过__proto__来访问该属性</p>
<p>原型对象就相当于一个公共的区域，所有同一个类的实例都可以访问到这个原型对象，没我可以将对象中共有的内容，统一设置到原型对象中。</p>
<p>当我们访问对象的一个属性或方法时，它先在自身中寻找，如果没有则会去原型对象中寻找，如果找到则直接使用</p>
<p>-以后创建构造函数时，可以将这些对象共有的属性和方法，统一添加到构造函数的原型对象中。这样不用分别为每个对象添加，也不会影响到全局作用域，就可以使每个对象都具有这些属性和方法</p>
<p>﻿</p>
<p>67.尚硅谷_JS基础_原型对象P67 - 00:03</p>
<p>﻿</p>
<p>使用in检查对象中是否含有某个属性时，如果对象中没有但是原型中有，也会返回true</p>
<p>可以使用对象的hasOwnProperty（）检查自身中是否含有该属性</p>
<p>原型对象也还有原型对象</p>
<p>-当我们在使用一个对象的属性或方法时，会先在自身中寻找，如果没有则去原型对象中寻找，如果原型对象中与他使用，再没有去原型的原型去寻找。</p>
<p>Object对象中的原型没有原型（最多两层），在Object中依然没有找到，则返回undefined。（原型链）</p>
<p>﻿</p>
<p>68.尚硅谷_JS基础_toString()P68 - 00:10</p>
<p>﻿</p>
<p>当直接在页面中打印一个对象时，事实上是输出对象的ToString（）方法的返回值（打印对象=打印返回值）</p>
<p>如果我们希望对象不输出【boject OBject】可以为对象添加一个ToString（）方法</p>
<p>﻿</p>
<p>69.尚硅谷_JS基础_垃圾回收P69 - 00:04</p>
<p>﻿</p>
<p>垃圾回收</p>
<p>对对象进行一系列操作之后，最后将对象的值改为object=null</p>
<p>当一个对象没有任何的变量或属性对它进行引用，此时我们永远无法操作该对象。</p>
<p>此时这种对象就是一个垃圾，导致程序变慢。在JS中拥有自动的垃圾回收机制。我们不需要也不能进行垃圾回收。如果需要回收就使用boject=null，让栈内存中的内存值设为null</p>
<p>﻿</p>
<p>70.尚硅谷_JS基础_数组简介P70 - 00:16</p>
<p>﻿</p>
<p>数组也是一个对象（Array）</p>
<p>和普通对象功能类似，也是用来储存一个值</p>
<p>不同的是普通对象是使用字符串作为属性名的，</p>
<p>-而数组时使用数字来作为索引操作元素</p>
<p>-索引：</p>
<p>从0开始的整数就是索引</p>
<p>数组的存储属性比普通对象好，在开发总我们经常使用数组来存储一些数据</p>
<p>使用typeof检查数组是返回object</p>
<p>语法：数组【索引】=值</p>
<p>arr[0]=10</p>
<p>读取数组中的元素</p>
<p>语法：数组【索引】</p>
<p>﻿ ﻿</p>
<p>像数组最后一个数组添加元素</p>
<p>语法：数组【数组.lenght】=值</p>
<p>﻿</p>
<p>71.尚硅谷_JS基础_数组字面量P71 - 00:49</p>
<p>﻿</p>
<p>可以直接使用var arr=[];创建数据</p>
<p>也可以使用构造函数的方法添加元素，将要添加元素构造函数的参数传递</p>
<p>var arr=new Array(10,20,30);</p>
<p>数组中的元素可以是任意的数据类型（包括对象）</p>
<p>arr=[“hello”,1,true,null,undefined]</p>
<p>﻿</p>
<p>72.尚硅谷_JS基础_数组的四个方法P72 - 00:15</p>
<p>﻿</p>
<p>push（）该方法可以想数组的末尾添加一个或多个元素，并返回数组的新的长度。这样这些元素将自动添加到数组的末尾</p>
<p>pop（）该方法可以删除数组的最后一个元素，并将删除的元素作为返回值返回</p>
<p>arr.unshift()往前面添加，想前面添加元素之后，其它的元素的下标都会调整。</p>
<p>arr.shift()删除数组的第一个元素并作返回值进行返回</p>
<p>﻿</p>
<p>73.尚硅谷_JS基础_数组的遍历P73 - 01:26</p>
<p>﻿</p>
<p>使用for循环来进行数组的遍历</p>
<p>arr.lenght</p>
<p>﻿</p>
<p>74.尚硅谷_JS基础_数组练习P74 - 01:07</p>
<p>﻿</p>
<p>﻿</p>
<p>75.尚硅谷_JS基础_forEachP75 - 00:07</p>
<p>﻿</p>
<p>了解一个forEach方法进行遍历数组</p>
<p>就是除了for循环的数组之外的遍历数组</p>
<p>arr.forEach(function(){})</p>
<p>forEach需要一个函数作为参数</p>
<p>-这种函数，由我们创建但是不由我们调用，我们成为回调函数</p>
<p>-数组中有几个数组就会执行几次，每次执行时，浏览器会将遍历到的元素以实参的形式传递进来，我们可以来定义形参，来读取这些内容</p>
<p>-浏览器会在回调函数中传递三个函数。</p>
<p>-第一个参数当前正在遍历的元素</p>
<p>-第二个参数当前正在遍历元素的索引</p>
<p>-第三个参数当前正在遍历的整个对象</p>
<p>支持IE8及以上的</p>
<p>﻿</p>
<p>76.尚硅谷_JS基础_slice和spliceP76 - 00:05</p>
<p>﻿</p>
<p>slice（）参数start，end开始和结束位置。该方法不会影响原数组。</p>
<p>截取位的索引包含开始不包含结束。前闭后开区间</p>
<p>-第二个参数可以省略不写。那就是全部截取</p>
<p>-索引也可以传递负值，如果传递一个负值那就是从后往前取</p>
<p>splice（）可以用于用于删除数组</p>
<p>splice（）会影响到原数组，会将制定元素从原数组中删除，并将删除的元素作为返回值返回。参数start，num。删除的从第几个开始以及删除的数量，第三个参数以后：可以传递新的元素，这些元素就会自动插入到开始位置索引前面</p>
<p>﻿</p>
<p>77.尚硅谷_JS基础_数组去重练习P77 - 00:06</p>
<p>﻿</p>
<p>﻿</p>
<p>78.尚硅谷_JS基础_数组的剩余方法P78 - 00:05</p>
<p>﻿</p>
<p>concat（）可以连接两个或多个数组，并将新的数组范围。该方法不会对原数组产生影响</p>
<p>join（）该方法可以将数组转换为一个字符串</p>
<p>-该方法不会对原数组产生影响，二十将转换后的字符串作为结果返回</p>
<p>-在join（）中可以指定一个字符串作为参数，这个字符串将成为数组中元素的连接符，如果不使用那就默认逗号，想要为空的话就改为一个空字符串</p>
<p>reverse（）该方法用来翻转数组，会直接修改原数组</p>
<p>sort（）对原数组进行排序，会影响原数组，按照Unicode编码进行排序。即使按照纯数字的数组排序，也会按照Unicode编码来排序，所以对数字排序的时候可能得到错误的结果</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>79.尚硅谷_JS基础_call和applyP79 - 00:01</p>
<p>﻿</p>
<p>函数对象的方法call()和apply()</p>
<p>-这两个方法都是函数对象的方法，需要通过函数对象来调用</p>
<p>-当我们对函数进行调用call()和apply()和直接加()就可以使用</p>
<p>-使用call()和apply()可以将一个对象指定为一个参数</p>
<p>此时这个对象将会成为函数执行的this</p>
<p>-call()方法可以将实参在对象之后一次传递</p>
<p>-apply()方法需要将实参封装到一个数组中统一传递</p>
<p>-this的情况：</p>
<p>1、以函数形式调用时，this永远都是window</p>
<p>2、以方法的形式调用时，this是调用方法的对象</p>
<p>3、以构造函数的形式调用时，this是新创建的对象</p>
<p>4、使用call和apply调用时，this是指定的那个对象</p>
<p>﻿</p>
<p>80.尚硅谷_JS基础_argumentsP80 - 00:23</p>
<p>﻿</p>
<p>在调用函数时，浏览器每次都会传递进两个隐含的参数。</p>
<p>1、第一个是函数的上下文对象this。</p>
<p>2、第二个是封装实参的arguments</p>
<p>-arguments是一个类数组对象（但是不是一个数组），它也可以通过参数索引来操作数据，也可以获取长度。</p>
<p>-在调用函数时，我们所传递的实参都会在arguments中保存</p>
<p>-即使不定义形参，也可以通过arguments的下标来使用实参。</p>
<p>-它里面还有一个属性叫做callee，对应的一个函数对象，就是我们当前正在执行的函数对象</p>
<p>﻿</p>
<p>81.尚硅谷_JS基础_Date对象P81 - 00:12</p>
<p>﻿</p>
<p>Date对象</p>
<p>-在JS中使用Date对象来表示一个时间</p>
<p>如果直接使用构造函数去创建一个Date对象，则会封装为当前代码的执行时间</p>
<p>创建指定的一个时间对象：格式：月份/日/年 时：分：秒</p>
<p>getDay（）返回当前日期的周几0表示周日，1周一</p>
<p>getMonth（）返回当前日期的月份</p>
<p>0表示1月，1表示2月，2表示3月</p>
<p>getTime（）返回当前日期对象的时间戳</p>
<p>-时间戳，指的是从格林威治的标准时间到现在的毫秒数的及时（计算机底层在保存时间使用时间戳保存）</p>
<p>获取我们当前的时间戳Date.Now();</p>
<p>﻿</p>
<p>82.尚硅谷_JS基础_MathP82 - 00:05</p>
<p>﻿</p>
<p>Math</p>
<p>-Math和其它对象不同，它不算一个构造函数。</p>
<p>术语工具类不用创建对象，它里面封装数学计算的方法</p>
<p>Math.ceil()方法小数点只要有值都自动进1。向上取整</p>
<p>Math.floor()方法小数点只要有值都自动抹去。向下取整</p>
<p>﻿</p>
<p>96.尚硅谷_JS基础_DOM查询P96 - 00:37</p>
<p>﻿</p>
<p>获取某个元素下的子元素，需要使用该元素名在寻找子元素名。语法：元素名.getElementById()</p>
<p>childnodes获取包括文本节点在内的所有节点。</p>
<p>根据DOM的换行也会当成文本节点，但是在IE8一下的浏览器中，不会将空白文本当成子节点，</p>
<p>children属性可以获取当前元素的子元素（不会有空格）比childnodes好很多</p>
<p>firstChild第一个子节点</p>
<p>firstElementChild第一个子元素（不支持IE8以下）</p>
<p>﻿</p>
<p>97.尚硅谷_JS基础_DOM查询P97 - 00:40</p>
<p>﻿</p>
<p>定义一个函数，专门用来指定元素绑定单击响应函数</p>
<p>参数：</p>
<p>idStr要绑定单机相应函数的对象的id属性值</p>
<p>fun事件回调函数，当点击元素时，使用回调函数</p>
<p>父节点：parentNode</p>
<p>innerHTML获取到元素内部中的html代码。而innerText则获取到元素内部中的文字，去除了标签部分</p>
<p>.previousSibling前一个兄弟节点（包括空格）</p>
<p>.previousElementSibling前一个兄弟元素</p>
<p>文本框的value属性值就是文本框中填写的内容</p>
<p>文本中的nodeValue就是他文本的值。</p>
<p>﻿</p>
<p>98.尚硅谷_JS基础_全选练习（一）P98 - 00:17</p>
<p>﻿</p>
<p>﻿</p>
<p>99.尚硅谷_JS基础_全选练习（二）P99 - 12:15</p>
<p>﻿</p>
<p>在时间的响应函数中，响应函数是给谁绑定的this就是</p>
<p>﻿</p>
<p>﻿</p>
<p>102.尚硅谷_JS基础_dom增删改P102 - 00:10</p>
<p>﻿</p>
<p>createElement（）可以创建一个元素节点对象，需要一个标签名作为参数，将会根据标签名创建元素节点对象，并将创建好的对象作为返回值</p>
<p>createTextNode()创建文本节点，需要一个文本内容作为参数，会根据该内容创建文本节点，将新的节点返回</p>
<p>appendChild（）向一个父节点添加一个新的子节点。</p>
<p>用法：父节点.appendChild(子节点)</p>
<p>﻿</p>
<p>103.尚硅谷_JS基础_添加删除记录-删除P103 - 00:11</p>
<p>﻿</p>
<p>﻿</p>
<p>104.尚硅谷_JS基础_添加删除记录-添加P104 - 00:08</p>
<p>﻿</p>
<p>﻿</p>
<p>104.尚硅谷_JS基础_添加删除记录-添加P104 - 00:42</p>
<p>﻿</p>
<p>﻿</p>
<p>105.尚硅谷_JS基础_添加删除记录-修改P105 - 00:26</p>
<p>﻿
﻿</p>
<p>108.尚硅谷_JS基础_获取元素的样式P108 - 00:37</p>
<p>﻿</p>
<p>document.style.样式获取的是内联样式并不是样式表中的样式</p>
<p>读取元素当前样式：</p>
<p>语法：元素.currentStyle.样式名</p>
<p>它可以用来读取当前正在显示的样式（虽然好用但是只有IE支持）</p>
<p>在其他浏览器中使用getComputedStyle()这个方法来获取当前的样式，这个方法是window的方法，可以直接使用。两个参数：第一个：要获取样式的元素，第二个：传递一个伪元素，一般都传null。该方法返回一个对象，对象中封装了当前元素的对应样式</p>
<p>该方法会返回一个对象，对象封装了当前元素对应的样式（该方法不支持IE8以下浏览器）</p>
<p>要做到都兼容自己写一个函数：</p>
<p>参数：obj获取样式的元素。name要获取的样式名。</p>
<p>通过currentStyle和getComputedStyle()读取到的样式都是只读的，不能修改，如果要修改必须通过style属性</p>
<p>﻿</p>
<p>109.尚硅谷_JS基础_getStyle()方法P109 - 00:04</p>
<p>﻿</p>
<p>找对象的属性而不是变量，找不到属性为undefined，所以他转换为false就是走else中的。但是如果找不到变量那就报错了</p>
<p>﻿</p>
<p>110.尚硅谷_JS基础_其他样式相关的属性P110 - 00:35</p>
<p>﻿</p>
<p>clientWidth可见宽度</p>
<p>clientHeight可见高度</p>
<p>-这些属性都不带PX，返回一个数字，可以直接计算</p>
<p>-获取元素宽度和高度，包括内容区和内边距</p>
<p>-这些属性都是只读的不能进行修改，只能通过style进行修改</p>
<p>offsetWidth</p>
<p>offsetHeight</p>
<p>-获取元素的整个的宽度和高度，包括内容与、内边距边框</p>
<p>offsetParent</p>
<p>-可以获取当前元素的定位父元素</p>
<p>-会获取到离当前元素最近的开启了定位的祖先元素</p>
<p>-如果所有的祖先元素都没有开启则返回body</p>
<p>offsetLeft</p>
<p>-当前元素相对于其定位元素的水平偏移量</p>
<p>OffsetTop</p>
<p>-当前元素相对于其定位元素的垂直偏移量</p>
<p>scrollWidth和scrollHeight</p>
<p>-当前元素的滚动区域的高度和宽度</p>
<p>scrollLeft</p>
<p>-可以获取水平滚动条滚动的距离</p>
<p>scrollTop</p>
<p>-可以获取垂直滚动条滚动的距离</p>
<p>当满足scrollHeight-scrollTop==clientHeight。说明垂直滚动条到底了。</p>
<p>当满足scrollWidth-scrollLeft==clientWidth。说明水平滚动条滚动到底</p>
<p>overflow：auto调出滚动条出来</p>
<p>﻿</p>
<p>111.尚硅谷_JS基础_事件对象P111 - 03:33</p>
<p>﻿</p>
<p>onmousemove</p>
<p>该事件会在鼠标在元素中移动时触发</p>
<p>事件对象</p>
<p>当事件的相应函数被触发时，浏览器每次都会将一个事件对象作为实参传递进响应函数</p>
<p>在事件对象中封装了当前事件相关的一切信息，比如：鼠标的坐标 键盘哪个按键被按下 鼠标的滚轮滚动方向。。。</p>
<p>在IE8中，响应函数被触发时，浏览器不会传递时间对象。</p>
<p>﻿</p>
<p>112.尚硅谷_JS基础_div跟随鼠标移动P112 - 01:45</p>
<p>﻿</p>
<p>div块鼠标跟着一起动</p>
<p>想要设置位置left和top就一定要开启绝对定位absolute</p>
<p>pageX和pageY可以获取相对于页面的定位</p>
<p>﻿</p>
<p>113.尚硅谷_JS基础_事件的冒泡P113 - 00:04</p>
<p>﻿</p>
<p>事件的冒泡（Bubble）</p>
<p>    -所谓的冒泡值的就是事件的向上传到，当后代的元素被触发时，祖先相同事件也会触发</p>
<p>    -在开发中大部分冒泡是有用的，如果不希望事件冒泡可以通过事件对象来取消冒泡</p>
<p>    </p>
<p>﻿</p>
<p>114.尚硅谷_JS基础_事件的委派P114 - 05:18</p>
<p>﻿</p>
<p>为每个超链接都绑定一个单击相应函数</p>
<p>这里我们为每一个超链接都绑定一个单机响应函数，这种操作麻烦，而且这些操作只能为已经有的添加设置时间，而重新添加的超链接必须重新绑定</p>
<p>我们希望，只绑定一次时间，即可应用到多个元素上，即使元素是后添加的，我们可以尝试绑定给元素共同的祖先元素</p>
<p>事件的委派：</p>
<p>-指将时间统一绑定给元素的共同的祖先元素，这样当后代元素的时间触发时，会一直冒泡到祖先元素从而通过祖先元素的响应函数来处理事件</p>
<p>-时间委派是利用了冒泡，通过委派可以减少时间绑定的次数，提高程序性能</p>
<p>﻿</p>
<p>115.尚硅谷_JS基础_事件的绑定P115 - 01:56</p>
<p>﻿</p>
<p>使用 对象.时间=函数 的形式绑定响应函数。</p>
<p>它只能同时为一个元素的一个事件绑定一个响应函数，不能绑定多个，如果绑定了多个，后面的会被覆盖</p>
<p>可以通过监听器的方法就可以addEventListener（）；</p>
<p>参数：1.时间的字符串，不要on。2.回调函数，3.是否在捕获阶段触发，需要一个布尔值，一般都传false。</p>
<p>使用addEventListener（）可以同时为一个元素的相同事件同时绑定多个响应函数，这样当事件被触发时，响应函数会按照函数绑定的顺序执行。</p>
<p>在IE8中可以使用attachEvent（）来绑定事件，</p>
<p>参数：1.事件的字符串，要on，2.回调函数</p>
<p>-这个方法也可以同时为一个时间绑定多个处理函数。不同的是后绑定先执行，执行顺序和addEventListener（）相反。</p>
<p>﻿</p>
<p>116.尚硅谷_JS基础_完成bind函数P116 - 00:00</p>
<p>﻿</p>
<p>﻿</p>
<p>117.尚硅谷_JS基础_事件的传播P117 - 00:43</p>
<p>﻿</p>
<p>事件的传播</p>
<p>-关于时间的传播微软和网景不同的理解</p>
<p>-微软公司认为事件应该是由内向外传播，也就是当事件触发时，应该先触发当前元素的事件，然后再向前元素的祖先元素上传播，也就是说应该在冒泡上实行。</p>
<p>-网景公司认为事件应该是由外向内传播的，也就是当前事件触发时，应该先触发当前元素外层的祖先事件。事件的捕获</p>
<p>W3C综合了两个公司的方案，将事件传播分为了三个阶段：</p>
<p>-1、捕获阶段</p>
<p>在捕获阶段时从最外层的祖先元素，向目标元素进行事件的捕获，但是默认此时不会触发事件。</p>
<p>-2、目标阶段</p>
<p>事件捕获到目标元素，捕获结束开始在目标元素上触发事件</p>
<p>-3、冒泡阶段</p>
<p>事件从目标元素向他的祖先元素传递，依次触发祖先元素上的事件</p>
<p>-如果希望在捕获阶段就将addEventListener中第三个参数设置为true。一般情况下我们不会希望在捕获触发。IE8以下没有</p>
<p>﻿</p>
<p>118.尚硅谷_JS基础_拖拽（一）P118 - 00:21</p>
<p>﻿</p>
<p>拖拽的过程</p>
<p>    1、当鼠标被拖拽元素按下，开始拖拽onmousedown</p>
<p>    2、当鼠标移动时拖拽元素跟随移动onmousemove</p>
<p>    3、当鼠标松开时元素固定当前位置onmouseup</p>
<p>﻿</p>
<p>119.尚硅谷_JS基础_拖拽（二）P119 - 01:48</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>﻿</p>
<p>120.尚硅谷_JS基础_拖拽（三）P120 - 04:54</p>
<p>﻿</p>
<p>﻿ ﻿</p>
<p>但是对IE8不起作用</p>
<p>当调用一个元素的setCapture()</p>
<p>﻿</p>
<p>121.尚硅谷_JS基础_滚轮的事件P121 - 00:11</p>
<p>﻿</p>
<p>鼠标滚轮滚动事件</p>
<p>onmousewheel（），在火狐中需要使用DOMMouseScroll来绑定滚动事件注意该事件需要通过addEventListener()函数来绑定火狐浏览器的滚动条时间，通过event.wheelDelta的正负值大小判断滑动轨迹</p>
<p>﻿</p>
<p>122.尚硅谷_JS基础_键盘事件P122 - 00:29</p>
<p>﻿</p>
<p>键盘事件：onkeydown、onkeyup键盘被按下、松开</p>
<p>键盘事件一般都会绑定到能够获取焦点的对象document</p>
<p>onkeydown：</p>
<p>-按键被按下</p>
<p>-对于onkeydown来说如果一直按着某个按键不松手，该事件会一直触发</p>
<p>-当onkeydown连续触发时，开始输入慢，防误操</p>
<p>altKey、ctrlKey、shiftKey公用按键用与方法判断是否被同时按下</p>
<p>﻿</p>
<p>124.尚硅谷_JS基础_NavigatorP124 - 01:19</p>
<p>﻿</p>
<p>Bom可以使我们通过JS来操作浏览器</p>
<p>在Bom中为我们提供了一组对象，用来完成浏览器的操作</p>
<p>Bom对象</p>
<p>-Window</p>
<p>代表的是整个浏览器的窗口，同时window也是网页中的全局对象</p>
<p>-Navigator</p>
<p>代表的当前浏览器的信息，通过该对象可以识别不同的浏览器。</p>
<p>由于历史原因Navigator对象</p>
<p>一般我们只会使用userAgent来判断浏览器的信息，就是一个字符串，这个字符串中包含有用来描述浏览器信息的内容，不同的浏览器有不同的userAgent</p>
<p>-Location</p>
<p>代表当前浏览器的地址栏信息，通过Location可以操作浏览器跳转页面</p>
<p>-History</p>
<p>代表浏览器的历史记录，可以通过该对象来操作浏览器的历史记录。由于隐私原因，该对象不能获取到具体的历史记录，只能操作浏览器向前或向后翻页。</p>
<p>而且此操作只在当次访问有效</p>
<p>-Screen</p>
<p>代表用户的屏幕的信息，通过该对象获得显示器的相关信息</p>
<p>这些BOM对象在浏览器中都是作为window对象的属性保存的。可以通过window对象来使用，也可以直接使用</p>
<p>﻿</p>
<p>124.尚硅谷_JS基础_NavigatorP124 - 41:05</p>
<p>﻿</p>
<p>找出IE的方法具体在代码里</p>
<p>﻿</p>
<p>125.尚硅谷_JS基础_HistoryP125 - 04:30</p>
<p>﻿</p>
<p>-History</p>
<p>代表浏览器的历史记录，可以通过该对象来操作浏览器的历史记录。由于隐私原因，该对象不能获取到具体的历史记录，只能操作浏览器向前或向后翻页。</p>
<p>而且此操作只在当次访问有效</p>
<p>﻿</p>
<p>126.尚硅谷_JS基础_LocationP126 - 00:07</p>
<p>﻿</p>
<p>-Location</p>
<p>该对象封装了对象中的地址栏信息</p>
<p>如果直接打印Location可以获取到地址栏完整信息如果直接将Location修改为一个完整路径或相对路径会自动跳转并生成响应历史记录</p>
<p>-assign()用以跳转，跟Location方法差不多</p>
<p>location..assign(“<a target="_blank" rel="noopener" href="http://www.baidu.com&quot;/">http://www.baidu.com&quot;</a>)</p>
<p>location.reload(true)进行强制清空缓存刷新</p>
<p>    location.replace()方法进行跳转不会生成历史记录不能回退</p>
<p>﻿</p>
<p>127.尚硅谷_JS基础_定时器简介P127 - 00:15</p>
<p>﻿</p>
<p>JS程序的执行速度是非常快的</p>
<p>定时调用，如果需要一段程序每间隔一段时间执行一次，可以使用定时调用</p>
<p>timer=setInterval()</p>
<p>-定时调用</p>
<p>-可以将一个函数，每隔一段时间事件执行一次</p>
<p>-参数：</p>
<p>1、回调函数，该函数每隔一段时间被调用一次</p>
<p>2、每次调用的时间间隔，单位是毫秒</p>
<p>关闭定时器：</p>
<p>返回一个Number类型的数据</p>
<p>clearInterval(timer)</p>
<p>128.尚硅谷_JS基础_切换图片练习P128 - 10:49</p>
<p>﻿</p>
<p>clearInterval（）可以接受任意参数</p>
<p>如果参数是一个有效的定时器的表示，则停止对应的定时器，如果参数是一个无效的不发生效果。</p>
<p>目前我们每次点一次按钮，则会开启一个定时器，</p>
<p>所以我们每次开启一个定时器之前都要关闭另一个当前元素的其它定时器</p>
<p>﻿</p>
<p>129.尚硅谷_JS基础_修改div移动练习P129 - 00:20</p>
<p>﻿</p>
<p>﻿</p>
<p>130.尚硅谷_JS基础_延时调用P130 - 00:03</p>
<p>﻿</p>
<p>延时调用</p>
<p>延时调用一个函数不马上执行，而是隔一段时间执行只执行一次</p>
<p>延时调用和定时调用的区别，定时调用会调用多次，延时调用只调用一次</p>
<p>延时调用和定时调用实际上是可以互相代替的，在开发中可以根据自己需要</p>
<p>﻿</p>
<p>131.尚硅谷_JS基础_定时器的应用（一）P131 - 00:03</p>
<p>﻿</p>
<p>把移动位置修改成为一个函数进行包装一下复用性强</p>
<p>﻿</p>
<p>133.尚硅谷_JS基础_定时器的应用（三）P133 - 00:18</p>

                
            </div>
            <hr/>

            

    <div class="reprint" id="reprint-statement">
        
            <div class="reprint__author">
                <span class="reprint-meta" style="font-weight: bold;">
                    <i class="fas fa-user">
                        文章作者:
                    </i>
                </span>
                <span class="reprint-info">
                    <a href="/about" rel="external nofollow noreferrer">Kevin</a>
                </span>
            </div>
            <div class="reprint__type">
                <span class="reprint-meta" style="font-weight: bold;">
                    <i class="fas fa-link">
                        文章链接:
                    </i>
                </span>
                <span class="reprint-info">
                    <a href="http://example.com/2021/03/09/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/">http://example.com/2021/03/09/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/</a>
                </span>
            </div>
            <div class="reprint__notice">
                <span class="reprint-meta" style="font-weight: bold;">
                    <i class="fas fa-copyright">
                        版权声明:
                    </i>
                </span>
                <span class="reprint-info">
                    本博客所有文章除特別声明外，均采用
                    <a href="https://creativecommons.org/licenses/by/4.0/deed.zh" rel="external nofollow noreferrer" target="_blank">CC BY 4.0</a>
                    许可协议。转载请注明来源
                    <a href="/about" target="_blank">Kevin</a>
                    !
                </span>
            </div>
        
    </div>

    <script async defer>
      document.addEventListener("copy", function (e) {
        let toastHTML = '<span>复制成功，请遵循本文的转载规则</span><button class="btn-flat toast-action" onclick="navToReprintStatement()" style="font-size: smaller">查看</a>';
        M.toast({html: toastHTML})
      });

      function navToReprintStatement() {
        $("html, body").animate({scrollTop: $("#reprint-statement").offset().top - 80}, 800);
      }
    </script>



            <div class="tag_share" style="display: block;">
                <div class="post-meta__tag-list" style="display: inline-block;">
                    
                        <div class="article-tag">
                            <span class="chip bg-color">无标签</span>
                        </div>
                    
                </div>
                <div class="post_share" style="zoom: 80%; width: fit-content; display: inline-block; float: right; margin: -0.15rem 0;">
                    <link rel="stylesheet" type="text/css" href="/libs/share/css/share.min.css">
<div id="article-share">

    
    <div class="social-share" data-sites="twitter,facebook,google,qq,qzone,wechat,weibo,douban,linkedin" data-wechat-qrcode-helper="<p>微信扫一扫即可分享！</p>"></div>
    <script src="/libs/share/js/social-share.min.js"></script>
    

    

</div>

                </div>
            </div>
            
                <style>
    #reward {
        margin: 40px 0;
        text-align: center;
    }

    #reward .reward-link {
        font-size: 1.4rem;
        line-height: 38px;
    }

    #reward .btn-floating:hover {
        box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2), 0 5px 15px rgba(0, 0, 0, 0.2);
    }

    #rewardModal {
        width: 320px;
        height: 350px;
    }

    #rewardModal .reward-title {
        margin: 15px auto;
        padding-bottom: 5px;
    }

    #rewardModal .modal-content {
        padding: 10px;
    }

    #rewardModal .close {
        position: absolute;
        right: 15px;
        top: 15px;
        color: rgba(0, 0, 0, 0.5);
        font-size: 1.3rem;
        line-height: 20px;
        cursor: pointer;
    }

    #rewardModal .close:hover {
        color: #ef5350;
        transform: scale(1.3);
        -moz-transform:scale(1.3);
        -webkit-transform:scale(1.3);
        -o-transform:scale(1.3);
    }

    #rewardModal .reward-tabs {
        margin: 0 auto;
        width: 210px;
    }

    .reward-tabs .tabs {
        height: 38px;
        margin: 10px auto;
        padding-left: 0;
    }

    .reward-content ul {
        padding-left: 0 !important;
    }

    .reward-tabs .tabs .tab {
        height: 38px;
        line-height: 38px;
    }

    .reward-tabs .tab a {
        color: #fff;
        background-color: #ccc;
    }

    .reward-tabs .tab a:hover {
        background-color: #ccc;
        color: #fff;
    }

    .reward-tabs .wechat-tab .active {
        color: #fff !important;
        background-color: #22AB38 !important;
    }

    .reward-tabs .alipay-tab .active {
        color: #fff !important;
        background-color: #019FE8 !important;
    }

    .reward-tabs .reward-img {
        width: 210px;
        height: 210px;
    }
</style>

<div id="reward">
    <a href="#rewardModal" class="reward-link modal-trigger btn-floating btn-medium waves-effect waves-light red">赏</a>

    <!-- Modal Structure -->
    <div id="rewardModal" class="modal">
        <div class="modal-content">
            <a class="close modal-close"><i class="fas fa-times"></i></a>
            <h4 class="reward-title">您的赏识是我前进的动力！</h4>
            <div class="reward-content">
                <div class="reward-tabs">
                    <ul class="tabs row">
                        <li class="tab col s6 alipay-tab waves-effect waves-light"><a href="#alipay">支付宝</a></li>
                        <li class="tab col s6 wechat-tab waves-effect waves-light"><a href="#wechat">微 信</a></li>
                    </ul>
                    <div id="alipay">
                        <img src="/medias/reward/alipay.jpg" class="reward-img" alt="支付宝打赏二维码">
                    </div>
                    <div id="wechat">
                        <img src="/medias/reward/wechat.png" class="reward-img" alt="微信打赏二维码">
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

<script>
    $(function () {
        $('.tabs').tabs();
    });
</script>

            
        </div>
    </div>

    

    

    

    

    

    

    

    

    

<article id="prenext-posts" class="prev-next articles">
    <div class="row article-row">
        
        <div class="article col s12 m6" data-aos="fade-up">
            <div class="article-badge left-badge text-color">
                <i class="fas fa-chevron-left"></i>&nbsp;上一篇</div>
            <div class="card">
                <a href="/2021/03/10/MySql%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/">
                    <div class="card-image">
                        
                        
                        <img src="/medias/featureimages/3.jpg" class="responsive-img" alt="数据库学习笔记">
                        
                        <span class="card-title">数据库学习笔记</span>
                    </div>
                </a>
                <div class="card-content article-content">
                    <div class="summary block-with-text">
                        
                            
                        
                    </div>
                    <div class="publish-info">
                        <span class="publish-date">
                            <i class="far fa-clock fa-fw icon-date"></i>2021-03-10
                        </span>
                        <span class="publish-author">
                            
                            <i class="fas fa-user fa-fw"></i>
                            Kevin
                            
                        </span>
                    </div>
                </div>
                
            </div>
        </div>
        
        
        <div class="article col s12 m6" data-aos="fade-up">
            <div class="article-badge right-badge text-color">
                本篇&nbsp;<i class="far fa-dot-circle"></i>
            </div>
            <div class="card">
                <a href="/2021/03/09/JavaScript%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/">
                    <div class="card-image">
                        
                        
                        <img src="/medias/featureimages/9.jpg" class="responsive-img" alt="JS学习笔记">
                        
                        <span class="card-title">JS学习笔记</span>
                    </div>
                </a>
                <div class="card-content article-content">
                    <div class="summary block-with-text">
                        
                            
                        
                    </div>
                    <div class="publish-info">
                            <span class="publish-date">
                                <i class="far fa-clock fa-fw icon-date"></i>2021-03-09
                            </span>
                        <span class="publish-author">
                            
                            <i class="fas fa-user fa-fw"></i>
                            Kevin
                            
                        </span>
                    </div>
                </div>

                
            </div>
        </div>
        
    </div>
</article>

</div>



<!-- 代码块功能依赖 -->
<script type="text/javascript" src="/libs/codeBlock/codeBlockFuction.js"></script>

<!-- 代码语言 -->

<script type="text/javascript" src="/libs/codeBlock/codeLang.js"></script>


<!-- 代码块复制 -->

<script type="text/javascript" src="/libs/codeBlock/codeCopy.js"></script>


<!-- 代码块收缩 -->

<script type="text/javascript" src="/libs/codeBlock/codeShrink.js"></script>


    </div>
    <div id="toc-aside" class="expanded col l3 hide-on-med-and-down">
        <div class="toc-widget card" style="background-color: white;">
            <div class="toc-title"><i class="far fa-list-alt"></i>&nbsp;&nbsp;目录</div>
            <div id="toc-content"></div>
        </div>
    </div>
</div>

<!-- TOC 悬浮按钮. -->

<div id="floating-toc-btn" class="hide-on-med-and-down">
    <a class="btn-floating btn-large bg-color">
        <i class="fas fa-list-ul"></i>
    </a>
</div>


<script src="/libs/tocbot/tocbot.min.js"></script>
<script>
    $(function () {
        tocbot.init({
            tocSelector: '#toc-content',
            contentSelector: '#articleContent',
            headingsOffset: -($(window).height() * 0.4 - 45),
            collapseDepth: Number('0'),
            headingSelector: 'h2, h3, h4'
        });

        // modify the toc link href to support Chinese.
        let i = 0;
        let tocHeading = 'toc-heading-';
        $('#toc-content a').each(function () {
            $(this).attr('href', '#' + tocHeading + (++i));
        });

        // modify the heading title id to support Chinese.
        i = 0;
        $('#articleContent').children('h2, h3, h4').each(function () {
            $(this).attr('id', tocHeading + (++i));
        });

        // Set scroll toc fixed.
        let tocHeight = parseInt($(window).height() * 0.4 - 64);
        let $tocWidget = $('.toc-widget');
        $(window).scroll(function () {
            let scroll = $(window).scrollTop();
            /* add post toc fixed. */
            if (scroll > tocHeight) {
                $tocWidget.addClass('toc-fixed');
            } else {
                $tocWidget.removeClass('toc-fixed');
            }
        });

        
        /* 修复文章卡片 div 的宽度. */
        let fixPostCardWidth = function (srcId, targetId) {
            let srcDiv = $('#' + srcId);
            if (srcDiv.length === 0) {
                return;
            }

            let w = srcDiv.width();
            if (w >= 450) {
                w = w + 21;
            } else if (w >= 350 && w < 450) {
                w = w + 18;
            } else if (w >= 300 && w < 350) {
                w = w + 16;
            } else {
                w = w + 14;
            }
            $('#' + targetId).width(w);
        };

        // 切换TOC目录展开收缩的相关操作.
        const expandedClass = 'expanded';
        let $tocAside = $('#toc-aside');
        let $mainContent = $('#main-content');
        $('#floating-toc-btn .btn-floating').click(function () {
            if ($tocAside.hasClass(expandedClass)) {
                $tocAside.removeClass(expandedClass).hide();
                $mainContent.removeClass('l9');
            } else {
                $tocAside.addClass(expandedClass).show();
                $mainContent.addClass('l9');
            }
            fixPostCardWidth('artDetail', 'prenext-posts');
        });
        
    });
</script>

    

</main>




    <footer class="page-footer bg-color">
    
        <link rel="stylesheet" href="/libs/aplayer/APlayer.min.css">
<style>
    .aplayer .aplayer-lrc p {
        
        display: none;
        
        font-size: 12px;
        font-weight: 700;
        line-height: 16px !important;
    }

    .aplayer .aplayer-lrc p.aplayer-lrc-current {
        
        display: none;
        
        font-size: 15px;
        color: #42b983;
    }

    
    .aplayer.aplayer-fixed.aplayer-narrow .aplayer-body {
        left: -66px !important;
    }

    .aplayer.aplayer-fixed.aplayer-narrow .aplayer-body:hover {
        left: 0px !important;
    }

    
</style>
<div class="">
    
    <div class="row">
        <meting-js class="col l8 offset-l2 m10 offset-m1 s12"
                   server="netease"
                   type="playlist"
                   id="2039019608"
                   fixed='true'
                   autoplay='false'
                   theme='#42b983'
                   loop='all'
                   order='random'
                   preload='auto'
                   volume='0.7'
                   list-folded='true'
        >
        </meting-js>
    </div>
</div>

<script src="/libs/aplayer/APlayer.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/meting@2/dist/Meting.min.js"></script>

    
    <div class="container row center-align" style="margin-bottom: 15px !important;">
        <div class="col s12 m8 l8 copy-right">
            Copyright&nbsp;&copy;
            
                <span id="year">2021</span>
            
            <span id="year">2021</span>
            <a href="/about" target="_blank">Kevin</a>
            |&nbsp;Powered by&nbsp;<a href="https://hexo.io/" target="_blank">Hexo</a>
            |&nbsp;Theme&nbsp;<a href="https://github.com/blinkfox/hexo-theme-matery" target="_blank">Matery</a>
            <br>
            
            
            
            
            
            
            <span id="busuanzi_container_site_pv">
                |&nbsp;<i class="far fa-eye"></i>&nbsp;总访问量:&nbsp;<span id="busuanzi_value_site_pv"
                    class="white-color"></span>&nbsp;次
            </span>
            
            
            <span id="busuanzi_container_site_uv">
                |&nbsp;<i class="fas fa-users"></i>&nbsp;总访问人数:&nbsp;<span id="busuanzi_value_site_uv"
                    class="white-color"></span>&nbsp;人
            </span>
            
            <br>
            
            <span id="sitetime">载入运行时间...</span>
            <script>
                function siteTime() {
                    var seconds = 1000;
                    var minutes = seconds * 60;
                    var hours = minutes * 60;
                    var days = hours * 24;
                    var years = days * 365;
                    var today = new Date();
                    var startYear = "2021";
                    var startMonth = "3";
                    var startDate = "29";
                    var startHour = "0";
                    var startMinute = "0";
                    var startSecond = "0";
                    var todayYear = today.getFullYear();
                    var todayMonth = today.getMonth() + 1;
                    var todayDate = today.getDate();
                    var todayHour = today.getHours();
                    var todayMinute = today.getMinutes();
                    var todaySecond = today.getSeconds();
                    var t1 = Date.UTC(startYear, startMonth, startDate, startHour, startMinute, startSecond);
                    var t2 = Date.UTC(todayYear, todayMonth, todayDate, todayHour, todayMinute, todaySecond);
                    var diff = t2 - t1;
                    var diffYears = Math.floor(diff / years);
                    var diffDays = Math.floor((diff / days) - diffYears * 365);
                    var diffHours = Math.floor((diff - (diffYears * 365 + diffDays) * days) / hours);
                    var diffMinutes = Math.floor((diff - (diffYears * 365 + diffDays) * days - diffHours * hours) /
                        minutes);
                    var diffSeconds = Math.floor((diff - (diffYears * 365 + diffDays) * days - diffHours * hours -
                        diffMinutes * minutes) / seconds);
                    if (startYear == todayYear) {
                        document.getElementById("year").innerHTML = todayYear;
                        document.getElementById("sitetime").innerHTML = "本站已安全运行 " + diffDays + " 天 " + diffHours +
                            " 小时 " + diffMinutes + " 分钟 " + diffSeconds + " 秒";
                    } else {
                        document.getElementById("year").innerHTML = startYear + " - " + todayYear;
                        document.getElementById("sitetime").innerHTML = "本站已安全运行 " + diffYears + " 年 " + diffDays +
                            " 天 " + diffHours + " 小时 " + diffMinutes + " 分钟 " + diffSeconds + " 秒";
                    }
                }
                setInterval(siteTime, 1000);
            </script>
            
            <br>
            
        </div>
        <div class="col s12 m4 l4 social-link social-statis">
    <a href="https://github.com/ZKQevin" class="tooltipped" target="_blank" data-tooltip="访问我的GitHub" data-position="top" data-delay="50">
        <i class="fab fa-github"></i>
    </a>



    <a href="mailto:773116395@qq.com" class="tooltipped" target="_blank" data-tooltip="邮件联系我" data-position="top" data-delay="50">
        <i class="fas fa-envelope-open"></i>
    </a>







    <a href="tencent://AddContact/?fromId=50&fromSubId=1&subcmd=all&uin=773116395" class="tooltipped" target="_blank" data-tooltip="QQ联系我: 773116395" data-position="top" data-delay="50">
        <i class="fab fa-qq"></i>
    </a>







</div>
    </div>
</footer>

<div class="progress-bar"></div>


    <!-- 搜索遮罩框 -->
<div id="searchModal" class="modal">
    <div class="modal-content">
        <div class="search-header">
            <span class="title"><i class="fas fa-search"></i>&nbsp;&nbsp;搜索</span>
            <input type="search" id="searchInput" name="s" placeholder="请输入搜索的关键字"
                   class="search-input">
        </div>
        <div id="searchResult"></div>
    </div>
</div>

<script type="text/javascript">
$(function () {
    var searchFunc = function (path, search_id, content_id) {
        'use strict';
        $.ajax({
            url: path,
            dataType: "xml",
            success: function (xmlResponse) {
                // get the contents from search data
                var datas = $("entry", xmlResponse).map(function () {
                    return {
                        title: $("title", this).text(),
                        content: $("content", this).text(),
                        url: $("url", this).text()
                    };
                }).get();
                var $input = document.getElementById(search_id);
                var $resultContent = document.getElementById(content_id);
                $input.addEventListener('input', function () {
                    var str = '<ul class=\"search-result-list\">';
                    var keywords = this.value.trim().toLowerCase().split(/[\s\-]+/);
                    $resultContent.innerHTML = "";
                    if (this.value.trim().length <= 0) {
                        return;
                    }
                    // perform local searching
                    datas.forEach(function (data) {
                        var isMatch = true;
                        var data_title = data.title.trim().toLowerCase();
                        var data_content = data.content.trim().replace(/<[^>]+>/g, "").toLowerCase();
                        var data_url = data.url;
                        data_url = data_url.indexOf('/') === 0 ? data.url : '/' + data_url;
                        var index_title = -1;
                        var index_content = -1;
                        var first_occur = -1;
                        // only match artiles with not empty titles and contents
                        if (data_title !== '' && data_content !== '') {
                            keywords.forEach(function (keyword, i) {
                                index_title = data_title.indexOf(keyword);
                                index_content = data_content.indexOf(keyword);
                                if (index_title < 0 && index_content < 0) {
                                    isMatch = false;
                                } else {
                                    if (index_content < 0) {
                                        index_content = 0;
                                    }
                                    if (i === 0) {
                                        first_occur = index_content;
                                    }
                                }
                            });
                        }
                        // show search results
                        if (isMatch) {
                            str += "<li><a href='" + data_url + "' class='search-result-title'>" + data_title + "</a>";
                            var content = data.content.trim().replace(/<[^>]+>/g, "");
                            if (first_occur >= 0) {
                                // cut out 100 characters
                                var start = first_occur - 20;
                                var end = first_occur + 80;
                                if (start < 0) {
                                    start = 0;
                                }
                                if (start === 0) {
                                    end = 100;
                                }
                                if (end > content.length) {
                                    end = content.length;
                                }
                                var match_content = content.substr(start, end);
                                // highlight all keywords
                                keywords.forEach(function (keyword) {
                                    var regS = new RegExp(keyword, "gi");
                                    match_content = match_content.replace(regS, "<em class=\"search-keyword\">" + keyword + "</em>");
                                });

                                str += "<p class=\"search-result\">" + match_content + "...</p>"
                            }
                            str += "</li>";
                        }
                    });
                    str += "</ul>";
                    $resultContent.innerHTML = str;
                });
            }
        });
    };

    searchFunc('/search.xml', 'searchInput', 'searchResult');
});
</script>

    <!-- 回到顶部按钮 -->
<div id="backTop" class="top-scroll">
    <a class="btn-floating btn-large waves-effect waves-light" href="#!">
        <i class="fas fa-arrow-up"></i>
    </a>
</div>


    <script src="/libs/materialize/materialize.min.js"></script>
    <script src="/libs/masonry/masonry.pkgd.min.js"></script>
    <script src="/libs/aos/aos.js"></script>
    <script src="/libs/scrollprogress/scrollProgress.min.js"></script>
    <script src="/libs/lightGallery/js/lightgallery-all.min.js"></script>
    <script src="/js/matery.js"></script>

    <!-- Baidu Analytics -->

    <!-- Baidu Push -->

<script>
    (function () {
        var bp = document.createElement('script');
        var curProtocol = window.location.protocol.split(':')[0];
        if (curProtocol === 'https') {
            bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
        } else {
            bp.src = 'http://push.zhanzhang.baidu.com/push.js';
        }
        var s = document.getElementsByTagName("script")[0];
        s.parentNode.insertBefore(bp, s);
    })();
</script>

    
    <script src="/libs/others/clicklove.js" async="async"></script>
    
    
    <script async src="/libs/others/busuanzi.pure.mini.js"></script>
    

    

    

    <!--腾讯兔小巢-->
    
    

    

    

    
    <script src="/libs/instantpage/instantpage.js" type="module"></script>
    

	<script src="https://cdn.jsdelivr.net/gh/Mculover666/live2d-widget/autoload.js"></script>
</body>

</html>
